草庐IT

option 43

全部标签

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby - 下载前获取文件大小并计算已经下载了多少 (http+ruby)

谁能帮帮我在我开始下载之前获取文件大小显示已经下载了多少%.require'net/http'require'uri'url="http://www.onalllevels.com/2009-12-02TheYangShow_Squidoo_Part1.flv"url_base=url.split('/')[2]url_path='/'+url.split('/')[3..-1].join('/')Net::HTTP.start(url_base)do|http|resp=http.get(URI.escape(url_path))open("test.file","wb")do|fi

ruby - 为 Notepad++ 的 Ruby 语法突出显示添加关键字

我正在尝试添加require和include作为Notepad++的Ruby关键字,但我遇到了一些麻烦。我修改了langs.model.xml文件的ruby​​语言标签如下:__FILE__anddefendinorselfunless__LINE__begindefined?ensuremoduleredosuperuntilBEGINbreakdofalsenextrescuethenwhenENDcaseelsefornilretrytruewhilealiasclasselsififnotreturnundefyieldrequireinclude但是,即使在更新此requir

ruby-on-rails - 为 nil :NilClass only with RubyMine debugger on 获取未定义的方法 `+'

我的环境:Ubuntu14Ruby2.2.1Rails4.2新创建的Rails应用程序,包含1个操作:classFramesController无论我在哪里放置断点(在当前情况下返回0),我都会在浏览器中收到此错误:undefinedmethod`+'fornil:NilClass只有当我在RubyMine中使用“调试”选项并且到达断点时才会发生。当我在没有调试器/断点的情况下运行服务器时,一切正常。 最佳答案 我有同样的问题,只是从Gemfile中删除byebuggem修复了它group:development,:testdo#C

ruby-on-rails - Ruby on Rails 3 + Apache2 + Phusion Passenger:Bundler::GemNotFound 异常

我正在尝试使用PhusionPassenger在Apache2服务器上部署Rails应用程序。虽然一切都在本地运行良好,但我在部署时遇到了臭名昭著的“Bundler::GemNotFound”错误:Couldnotfindabstract-1.0.0inanyofthesources(Bundler::GemNotFound)我所有的gem都安装在我的本地主文件夹中。因此,我的Apache2配置文件中的乘客配置行如下:LoadModulepassenger_module/home/regis/.gem/gems/passenger-3.0.7/ext/apache2/mod_passe

ruby-on-rails - 如果是正数,则使用 "+"前缀数字 - Ruby/Rails 4

我想知道传统的Rails方法和Ruby方法是在数字前面加上一个“+”sybmol(如果它是正数)。例子:应该输出:+5默认情况下,负数会正确显示:输出:-3我知道我可以做类似下面的事情:0)?'+':''%>但我不喜欢那样。在Ruby和Rails中执行此操作的好方法是什么,或者如果它们相同,则对两者执行此操作的好方法是什么? 最佳答案 查看sprintfmethodsprintf("%+d",123)1.9.3-p392:005>sprintf("%+d",123)=>"+123"1.9.3-p392:008>sprintf("%+

ruby - RVM + Zsh "RVM is not a function, selecting rubies with ' rvm 使用.. .' will not work"

首先我要说我不是命令行专家,所以我真的几乎不知道自己在做什么。我无法让RVM和oh-my-zsh一起玩得很好。我尝试了几种不同的解决方案,其中一些是在SO上发布的,但我发现似乎没有任何解决方案可以解决问题。最初,其他人在我的机器上安装了RVM。后来我自己设置了oh-my-zsh,记得当时遇到了很多麻烦。除了这两行,我的.zhsrc文件是完全默认的exportPATH=$HOME/bin:/usr/local/bin:/usr/local/rvm/bin:$PATH#prettysurethislinedoesnothing,althoughI'veseenthisfixaround#s

c - Memcached ruby​​gem + Rlibmemcached 参数错误与 memcache_mget()

我在使用EvanWeaver的Memcachedgem(如Memcached::Rails.new)->(http://github.com/fauna/memcached)并调用get_multi()时遇到异常ArgumentError:wrong#ofarguments(2for4)from/usr/local/lib/ruby/gems/1.8/gems/memcache-auth-1.0.1/lib/memcached/memcached.rb:384:in`memcached_mget'from/usr/local/lib/ruby/gems/1.8/gems/memcach

ruby - 在 Ruby + TinyTDS 中参数化 SQL 查询

我试图弄清楚如何在将SQL字符串交给执行之前对其进行参数化,但遗憾的是我发现了很多ofthis在互联网上:sql="SELECT*FROMtable_nameWHEREthingLIKE'%#{input}%'"这是一件坏事...但是,参数化sql查询在底层可用Sequel库,这是TinyTDS构建的基础。所以我知道这是可能的。我只是很难弄明白。我真的希望它能像this一样简单:@client=TinyTds::Client.new(:adapter=>'sqlserver',:host=>host,:database=>db,:username=>username,:password

ruby - "(1..4).inject(&:+)"在 Ruby 中如何工作

我发现这段Ruby代码非常有趣(1..4).inject(&:+)好的,我知道inject是做什么的,我知道这段代码基本上等同于(1..4).inject(0){|a,n|a+n}但它究竟是如何工作的呢?为什么&:+和写block{|a,n|是一样的a+n}?为什么不需要初始值?我同意初始值为0,但是(1..4).inject(&:*)也可以,并且初始值必须为1... 最佳答案 来自Rubydocumentation:Ifyouspecifyasymbolinstead,theneachelementinthecollectionw